package com.habdqn.attendance.service;

import com.habdqn.attendance.entity.Department;
import com.habdqn.attendance.entity.example.DepartmentExample;

import java.util.List;

/**
 * 部门表(Department)表服务接口
 *
 * @author makejava
 * @since 2019-10-23 14:35:13
 */
public interface DepartmentService {

    /**
     * 通过ID查询单条数据
     *
     * @param id 主键
     * @return 实例对象
     */
    Department queryById(Integer id);

    /**
     * 查询分页数据
     *
     * @param likeName 查询名称
     * @param pageNo 页码
     * @param pageSize  每页
     * @return 对象列表
     */
    List<Department> queryAllByPage(String likeName, int pageNo, int pageSize);

    /**
     * 查询所有部门
     *
     * @return 部门集合
     */
    List<Department> queryAll();

    /**
     * 新增数据
     *
     * @param department 实例对象
     * @return 实例对象
     */
    Department insert(Department department);

    /**
     * 修改数据
     *
     * @param department 实例对象
     * @return 实例对象
     */
    Department update(Department department);

    /**
     * 通过主键删除数据
     *
     * @param id 主键
     * @return 是否成功
     */
    boolean deleteById(Integer id);

    /**
     * 根据部门编号批量删除部门
     *
     * @param ids 部门编号，多个编号用","分隔
     * @return 是否删除成功
     */
    boolean batchDeleteByIds(String ids);

    /**
     * 获取总记录数
     *
     * @param likeName 模糊部门名
     * @return 部门数量
     */
    int getAllCount(String likeName);

}